Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support overriding state options #193

Merged

Conversation

zklgame
Copy link
Contributor

@zklgame zklgame commented Jul 25, 2023

This MR did:

  • Support WorkflowStateOptions overriding during StateMovement.create.
    • Build all kinds of the create methods with the parameter final Class<? extends WorkflowState> stateClass since they are more commonly used.

@zklgame zklgame requested a review from longquanzheng July 25, 2023 15:06
@codecov
Copy link

codecov bot commented Jul 25, 2023

Codecov Report

Merging #193 (11b7a8c) into main (cdeb5e1) will increase coverage by 0.18%.
The diff coverage is 76.92%.

@@             Coverage Diff              @@
##               main     #193      +/-   ##
============================================
+ Coverage     71.17%   71.36%   +0.18%     
- Complexity      362      366       +4     
============================================
  Files            59       59              
  Lines          1523     1526       +3     
  Branches        132      135       +3     
============================================
+ Hits           1084     1089       +5     
+ Misses          369      368       -1     
+ Partials         70       69       -1     
Files Changed Coverage Δ
src/main/java/io/iworkflow/core/StateDecision.java 62.12% <50.00%> (-0.57%) ⬇️
src/main/java/io/iworkflow/core/StateMovement.java 72.41% <90.90%> (+5.74%) ⬆️
.../io/iworkflow/core/mapper/StateMovementMapper.java 78.94% <100.00%> (+8.35%) ⬆️

📣 We’re building smart automated test selection to slash your CI/CD build times. Learn more

* @param stateOptions required, to override the defined ones in the State class
* @return state decision
*/
public static StateDecision singleNextState(final Class<? extends WorkflowState> stateClass, final WorkflowStateOptions stateOptions) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We probably have to remove this one, because it's going to be ambiguous with singleNextState(final Class<? extends WorkflowState> stateClass, final Object stateInput). The behavior is undefined with this ambiguity (different based on JVMs). The pattern with stateInput is much more popular so we should keep the other one

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Which JVM will have errors?

I think Java is a storng-typed langauge so that it will choose the most specific method. It means when the second parameter's type is not of WorkflowStateOptions, it will treat the parameter as input?

Copy link
Contributor

@longquanzheng longquanzheng Jul 26, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh I think you are probably right about jvm. The ambiguous case probably won’t happen in this case. (Though it happened before with vararg when I worked on other projects)

But I think it is still better to remove this because it’s not worth having this confusing method here. Also like you mentioned, there are too many of them. The use case of using stateOptionOverride is very rare

*
* @param stateClass required
* @param stateInput required
* @param stateOptions required, to override the defined ones in the State class
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's better to stateOptions => stateOptionsOverride to be more clear

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

also other methods in this file

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we should say "optional" for stateInput and stateOptionsOveride, because they can be null. Or to be more clear optional, can be null

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We have other methods public static StateDecision singleNextState(final Class<? extends WorkflowState> stateClass ...) without the input or option parameter. In the case of any of them being null, users should call these methods will less parameters?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah user should call that one. I just feeling like the word “required” is a bit confusing here as you can pass a “null”. Or you can put “can be null” to be clear

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

basically, if it's "required" because it's a parameter of the method, then I think this information is not useful -- user already know it's "required" by the compiler/IDE already.

So I think you can change it to "optional", or just say "can be null", without saying it's optional or required,

@@ -10,6 +11,7 @@ public abstract class StateMovement {
public abstract String getStateId();

public abstract Optional<Object> getStateInput();
public abstract Optional<WorkflowStateOptions> getStateOptions();
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

same here getStateOptionsOverride, and other methods in this file

return ImmutableStateMovement.builder().stateId(stateId)
.stateInput(stateInput)
.build();
public static StateMovement create(final Class<? extends WorkflowState> stateClass, final WorkflowStateOptions stateOptions) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

same here, this will be ambiguous for JVM. stateOptionsOverride is not a popular pattern, so we should keep the one with stateInput

* @param stateIds stateIds of next states
* @return state decision
*/
public static StateDecision multiNextStates(final String... stateIds) {
final ArrayList<StateMovement> stateMovements = new ArrayList<StateMovement>();
Arrays.stream(stateIds).forEach(id -> {
stateMovements.add(StateMovement.create(id));
stateMovements.add(StateMovement.create(id, null, null));
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I guess we don't have to pass in null, null

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I only keep one method with id because I think it's not commonly used and there are too many methods now. Maybe a better way is to add another method with id only.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh I see. Yeah agreed, I am okay to remove keep this one only.

@zklgame zklgame force-pushed the zklgame/support_overriding_state_options branch from 5f0f506 to 11b7a8c Compare July 27, 2023 03:53
@zklgame zklgame requested a review from longquanzheng July 27, 2023 03:55
@zklgame zklgame merged commit 757eed4 into indeedeng:main Jul 27, 2023
@zklgame zklgame deleted the zklgame/support_overriding_state_options branch July 27, 2023 04:13
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants